/* $Id: minixml.h,v 1.1.1.1 2012/02/17 03:45:26 hzheng Exp $ */
/* minimal xml parser
 *
 * Project : miniupnp
 * Website : http://miniupnp.free.fr/
 * Author : Thomas Bernard
 * Copyright (c) 2005 Thomas Bernard
 * This software is subject to the conditions detailed in the
 * LICENCE file provided in this distribution.
 * */
#ifndef __MINIXML_H__
#define __MINIXML_H__
#define IS_WHITE_SPACE(c) ((c==' ') || (c=='\t') || (c=='\r') || (c=='\n'))

/* if a callback function pointer is set to NULL,
 * the function is not called */
struct xmlparser {
	/*const*/ char *xmlstart;
	/*const*/ char *xmlend;
	/*const*/ char *xml;	/* pointer to current character */
	int xmlsize;
	void * data;
	int (*starteltfunc) (void *, const char *, unsigned, const char *, unsigned);
	int (*endeltfunc) (void *, const char *, unsigned, const char *, unsigned);
	int (*datafunc) (void *, const char *, unsigned);
	int (*attfunc) (void *, const char *, unsigned, const char *, unsigned, const char *, unsigned);
};

/* parsexml()
 * the xmlparser structure must be initialized before the call
 * the following structure members have to be initialized :
 * xmlstart, xmlsize, data, *func
 * xml is for internal usage, xmlend is computed automatically */
int parsexml(struct xmlparser *);

#endif

